﻿using System;
using System.Collections.Generic;
using System.Linq;

namespace HCMUS_SearchService_Group2
{
    /////////////////////////////////////////////////
    /// \brief Lớp truy xuất dữ liệu từ bảng TINHTHANH của CSDL.
    /// \details <h3>Cung cấp các phương thức để truy xuất dữ liệu từ CSDL</h3>
    /////////////////////////////////////////////////
    public class CityDAO : ObjectDAO, IObjectDAO
    {
        /////////////////////////////////////////////////
        /// \brief Hàm lấy dữ liệu
        /// \returns List<ObjectDTO>.
        /// \details <h3>Lấy toàn bộ dữ liệu của bảng TINHTHANH.</h3>
        /////////////////////////////////////////////////
        public List<ObjectDTO> GetAllDTO()
        {
            List<TINHTHANH> listTinhThanh = new List<TINHTHANH>();
            List<ObjectDTO> listTinhThanhDTO = new List<ObjectDTO>();
            listTinhThanh = (from city in DataConnectionHelper.Context.TINHTHANHs select city).ToList();
            foreach (var list in listTinhThanh)
            {
                CityDTO temp = new CityDTO() { CityID = list.MaTinhThanh, CityName = list.TenTinhThanh };
                listTinhThanhDTO.Add(temp);
            }

            return listTinhThanhDTO;
        }

        /////////////////////////////////////////////////
        /// \brief Hàm lấy dữ liệu
        /// \param[in] int id.
        /// \returns ObjectDTO.
        /// \details <h3>Trả về đối tượng ObjectDTO có id tương ứng.</h3>
        /////////////////////////////////////////////////
        public ObjectDTO Search(int id)
        {
            IEnumerable<CityDTO> city = new List<CityDTO>();
            CityDTO cityDTO = new CityDTO();
            city = from temp in SearchHelper.Citys where id == temp.CityID select temp;
            if (city.Count() != 0)
            {
                cityDTO.CityID = city.First().CityID;
                cityDTO.CityName = city.First().CityName;
            }

            return cityDTO;
        }

        /////////////////////////////////////////////////
        /// \brief Hàm lấy dữ liệu
        /// \param[in] string name.
        /// \returns int.
        /// \details <h3>Trả về id của đối tượng có tên tương ứng.</h3>
        /////////////////////////////////////////////////
        public int GetIdByName(string name)
        {
            int id;
            IEnumerable<int> temp = new List<int>();
            temp = from dist in SearchHelper.Citys where name.CompareTo(dist.CityName) == 0 select dist.CityID;
            if (temp.Count() != 0)
            {
                id = temp.First();
            }
            else
            {
                id = -1;
            }

            return id;
        }
    }
}
